package com.eclink.asset.config;

import com.github.xiaoymin.knife4j.spring.annotations.EnableKnife4j;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;

@Configuration
public class Knife4jConfig {

    @Bean(value = "allApi")
    public Docket createAllRestApi() {
        // Swagger 2 使用的是：DocumentationType.SWAGGER_2
        // Swagger 3 使用的是：DocumentationType.OAS_30
        return new Docket(DocumentationType.OAS_30)
                // 定义是否开启swagger，false为关闭，可以通过变量控制
                .enable(true)
                // 将api的元信息设置为包含在json ResourceListing响应中。
                .apiInfo(new ApiInfoBuilder()
                        .title("资产管理系统接口文档")
                        // 描述
                        .description("资产管理系统api")
                        .contact(new Contact("陈仕贤", "地址", "tntxia@163.com"))
                        .version("1.0.0")
                        .build())
                // 分组名称
                .groupName("全部接口")
                // 选择哪些接口作为swagger的doc发布
                .select()
                // 要扫描的API(Controller)基础包
//                .apis(RequestHandlerSelectors.basePackage("com.eclink.asset.asset.controller"))
//                                .apis(RequestHandlerSelectors.basePackage("com.eclink.asset.consume.controller"))
                //                .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class))
                .paths(PathSelectors.any())
                .build();
    }

    @Bean(value = "assetApi")
    public Docket createAssetRestApi() {
        // Swagger 2 使用的是：DocumentationType.SWAGGER_2
        // Swagger 3 使用的是：DocumentationType.OAS_30
        return new Docket(DocumentationType.OAS_30)
                // 定义是否开启swagger，false为关闭，可以通过变量控制
                .enable(true)
                // 将api的元信息设置为包含在json ResourceListing响应中。
                .apiInfo(new ApiInfoBuilder()
                        .title("资产管理系统接口文档")
                        // 描述
                        .description("资产管理系统api")
                        .contact(new Contact("陈仕贤", "地址", "tntxia@163.com"))
                                .version("1.0.0")
                                .build())
                                // 分组名称
                                .groupName("资产管理")
                                // 选择哪些接口作为swagger的doc发布
                                .select()
                                // 要扫描的API(Controller)基础包
                                .apis(RequestHandlerSelectors.basePackage("com.eclink.asset.asset.controller"))
//                                .apis(RequestHandlerSelectors.basePackage("com.eclink.asset.consume.controller"))
                                //                .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class))
                                .paths(PathSelectors.any())
                                .build();
    }

    @Bean(value = "consumeApi")
    public Docket createConsumeRestApi() {
        // Swagger 2 使用的是：DocumentationType.SWAGGER_2
        // Swagger 3 使用的是：DocumentationType.OAS_30
        return new Docket(DocumentationType.OAS_30)
                // 定义是否开启swagger，false为关闭，可以通过变量控制
                .enable(true)
                // 将api的元信息设置为包含在json ResourceListing响应中。
                .apiInfo(new ApiInfoBuilder()
                        .title("Knife4j接口文档")
                        // 描述
                        .description("平台服务管理api")
                        .contact(new Contact("作者", "地址", "邮箱或联系方式"))
                        .version("1.0.0")
                        .build())
                // 分组名称
                .groupName("耗材管理")
                // 选择哪些接口作为swagger的doc发布
                .select()
                // 要扫描的API(Controller)基础包
                .apis(RequestHandlerSelectors.basePackage("com.eclink.asset.consume.controller"))
//                                .apis(RequestHandlerSelectors.basePackage("com.eclink.asset.consume.controller"))
                //                .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class))
                .paths(PathSelectors.any())
                .build();
    }
}

